package com.atguigu.gulimall.coupon;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

/**
 * 1.如何使用Nacos作为配置中心统一管理配置
 *     1）、引入依赖
 *     <!--        nacos做配置中心-->
 *         <dependency>
 *             <groupId>com.alibaba.cloud</groupId>
 *             <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
 *         </dependency>
 *     2）、创建一个bootstrap.properties。
 *     spring.application.name=gulimall-coupon
         * #兼容了服务注册中心与配置中心
         * spring.cloud.nacos.config.server-addr=127.0.0.1:8848
 *     3）需要给配置中心默认添加一个叫数据集（Data ID） gulimall-coupon.properties.默认规则，应用名.properties
 *     4）、 给应用名.properties添加任何配置
 *     5）、动态获取配置
 * @RefreshScope：    动态获取并刷新配置
 * @Value ： （${user.name})  获取到配置
 *         如果配置中心和配置文件中都使用到了相同的项，优先使用配置中心中的配置
 *
 * 2.细节
 *     1）、命名空间： 配置隔离：
 *        默认： public（保留空间）： 默认新增的所有配置都在public空间
 *        1.）、开发，测试，生产：利用命名空间来做环境隔离
 *        注意： 在bootstrap.properties：配置上， 需要指定使用哪个命名空间
 *        spring.cloud.nacos.config.namespace=  UUID
 *        2）、每一个微服务之间相互隔离配置，每一个微服务都创建自己的命名空间，只加载自己命名空间下的所有配置
 *
 *     2）、配置集： 所有的配置的集合
 *     3）、配置集ID： 类似文件名。
 *          DataID：   类似文件名
 *     4）、配置分组 ：
 *     默认所有的分组都属于：DEFAULT——GROUP；
 *     1111,618,1212
 *
 *     每个微服务创建自己的命名空间，使用配置分组区分环境，dev，test，prod
 *
 *3.同时加载多个配置集
 * 1）、微服务任何配置信息，任何配置文件都可以放在配置中心中
 * 2）、只需要在bootstrap.properties说明加载配置中心中哪些配置文件即可
 * 3）、 获取值的注解  @Value  @ConfigurationProperties
 * 以前springboot任何方式从配置文件中获取值，都能使用
 * 配置中心有的优先使用配置中心中的、
 *
 *
 */
@SpringBootApplication
@EnableDiscoveryClient                  // 使用 @EnableDiscoveryClient 注解开启服务注册与发现功能

public class GulimailCouponApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimailCouponApplication.class,args);
    }
}
